A date in a calendar is a reference to a particular day represented within a calendar system. The calendar date allows the specific day to be identified. The number of days between two dates may be calculated. For example, "24 February 2012" is ten days after "14 February 2012" in the Gregorian calendar. The date of a particular event depends on the observed UTC offset. For example the attack on Pearl Harbor that began at 1941-12-07T18:18Z took place on 7 December according to Hawaii Time (UTC-10:30), and on 8 December according to Japan Standard Time (UTC+09).
A particular day may be represented by a different date in another calendar as in the Gregorian calendar and the Julian calendar, which have been used simultaneously in different places. In most calendar systems, the date consists of three parts: the day of month, month, and the year. There may also be additional parts, such as the day of week. Years are usually counted from a particular starting point, usually called the epoch, with era referring to the particular period of time (Note the different use of the terms in geology).
The most widely used epoch is a conventional birthdate of Jesus (which was established by Dionysius Exiguus in the sixth century). A date without the year part may also be referred to as a date or calendar date (such as "15 February" rather than "15 February 2012"). As such, it defines the day of an annual event, such as a birthday or Christmas on 25 December.
Contents |
Foundation c type double is used to store a date in iOS typedef NSTimeInterval whose integer representation is said to represent seconds.[1]
Foundation c type double records a real number consuming a total of 64 bits. 52 of which represent precision. 11 of which represent decimal point location. The only remaining bit indicates positive/negative.[2]
The number of seconds specified by the real number take meaning after zero is defined. iOS supports two definitions for zero which originally was 1 January 1970, GMT and has now become 1 January 2001, GMT. [3]
The date representation is said to give "precision within milliseconds for dates 10,000 years apart."[4]
A millisecond may seem precise, but can seem course when considering ticks of the CPU. As distance from zero increases, the more important larger integer value must be recorded causing the fractional second representation to become less precise. An object oriented environment may change the definition of zero, however, dates are so common that the object orientation is hardly ever recorded. The clock of a CPU and instruction execution time is no longer predictable. Therefore, an external clock is used to track elapsed time, and should economically use the same standard as NSTimeInterval. ASCII style records in a more human-like form which makes program issues easier to locate and resolve. However, as shown below, ASCII time specifications have their inherent flaws.
This sequence is common to the vast majority of the world's countries. This date format originates from the custom of writing the date as 'the 8th day of November in the year of our Lord 2003' in western religious and legal documents, which at one time were the majority of documents created. The format has shortened over time but the order of the elements has remained constant.
In this format the most significant data item is written before lesser data items i.e. year before month before day. It is consistent with the big endianness of the Indian decimal numbering system, which progresses from the highest to the lowest order magnitude. That is, using this format textual orderings and chronological orderings are identical. This form is standard in Asian countries, Hungary, Sweden and the US armed forces.
Examples for the 9th of November 2003:
It is also extended through the universal big-endian format clock time: 9 November 2003, 18h 14m 12s, or 2003/11/9/18:14:12 or (ISO 8601) 2003-11-09T18:14:12.
This sequence is used primarily in the United States, partially in Canada, and a few other countries . This date format was commonly used alongside the small endian form in the United Kingdom until the early 20th Century, and can be found in both defunct and modern print media such as the London Gazette and The Times, respectively. In the UK, it would be verbally expressed as Sunday, November the 9th, whereas in the United States, it is usually Sunday, November 9th, although usage of "the" isn't uncommon.
The many numerical forms can create confusion when used in international correspondence, particularly when abbreviating the year to its final two digits.
For example, "9/11" can refer to both the Fall of the Berlin Wall on 9 November 1989 and to September 11 attacks. In the United States, dates are rarely written in purely numerical forms in formal writing, although they are very common elsewhere; when numerical forms are used, the month appears first. In the United Kingdom, while it is regarded as acceptable to write month-name day, year, this order is never used when written numerically, although, due to American media influence, the American shorthand "9/11" is widely understood as referring to the 11 September 2001 terrorist attacks.[6]
When numbers are used to represent months, a significant amount of confusion can arise from the ambiguity of a date order; especially when the numbers representing the day, month or year are low, it can be impossible to tell which order is being used. This can be clarified by using four digits to represent years, and naming the month; for example, "Feb" instead of "02". Many Internet sites use year-month-day, and those using other conventions often write out the month (9-MAY-2001, MAY 09 2001, and so on.) so there is no ambiguity. The ISO 8601 date order, with four-digit years, is specifically chosen to be unambiguous. The ISO 8601 standard also has the advantage of being language independent and is therefore useful when there may be no language context and a universal application is desired (expiration dating on export products, for example).
In addition, the ISO considers its ISO 8601 standard to make sense from a logical perspective.[7] Mixed units, for example feet and inches, or pounds and ounces, are normally written with the largest unit first, in decreasing order. Numbers are also written in that order, so the digits of 2006 indicate, in order, the millennium, the century within the millennium, the decade within the century, and the year within the decade. The only date order that is consistent with these well-established conventions is year-month-day. A plain text list of dates with this format can be easily sorted by word processors, spreadsheets and other software tools with built-in sorting functions.
An early U.S. Federal Information Processing Standard recommended 2-digit years. This is now widely recognized as a bad idea, because of the year 2000 problem. Some U.S. government agencies now use ISO 8601 with 4-digit years.[8][9]
When transitioning from one date notation to another, people often write both Old Style and New Style dates.
One of the advantages of using the ISO 8601 standard date format is that the lexicographical order (ASCIIbetical) of the representations is equivalent to the chronological order of the dates. Thus dates can be sorted using simple string comparison algorithms, and indeed by any left to right collation. For example:
1998-02-28 (28 February 1998) sorts before 1999-03-01 (1 March 1999) which sorts before 2000-01-30 (30 January 2000)
The YYYY MM DD layout is the only common format that can provide this.[10] Sorting other date representations involves some parsing of the date strings. This also works when a time in 24-hour format is included after the date, as long as all times are understood to be in the same time zone.
ISO 8601 is used widely where concise, human readable yet easily computable and unambiguous dates are required, although many applications store dates internally as UNIX time and only convert to ISO 8601 for display. It is worth noting that all modern computer Operating Systems retain date information of files outside of their titles, allowing the user to choose which format they prefer and have them sorted thus, irrespective of the files' names.
The U.S. military sometimes uses a system, which they call "Julian date format"[11] that indicates the year and the actual day out of the 365 days of the year (and thus a designation of the month would not be needed). For example, "11 December 1999" can be written in some contexts as "1999345" or "99345", for the 345th day of 1999.[12] This system is most often used in US military logistics, since it makes the process of calculating estimated shipping and arrival dates easier. For example: say a tank engine takes an estimated 35 days to ship by sea from the US to Korea. If the engine is sent on 99104, it should arrive on 99139. Note that outside of the US military and some US government agencies, including the Internal Revenue Service, this format is usually referred to as "ordinal date", rather than "Julian date" [13]
Such ordinal date formats are also used by many computer programs (especially those for mainframe systems). Using a three-digit Julian day number saves one byte of computer storage over a two-digit month plus two-digit day, for example,, "January 17" is 017 in Julian versus 0117 in month-day format. OS/390 or its successor, z/OS, display dates in yy.ddd format for most operations. It is important to not confuse any of these formats with UNIX time, which stores time as a number in seconds since 1970-01-01.
Another "ordinal" date system ("ordinal" in the sense of advancing in value by one as the date advances by one day) is in common use in astronomical calculations and referencing and uses the same name as this "logistics" system. The continuity of representation of period regardless of the time of year being considered is highly useful to both groups of specialists. The astronomers describe their system as also being a "Julian date" system. Unlike the system described above, the astronomical system does not consider years, it only counts days. Thus it is unperturbed by complications such as leap years.
Companies in Europe often use year, week number and day for planning purposes. So, for example, an event in a project can happen on w43 (week 43) or w43-1 (Monday, week 43) or, if the year needs to be indicated, on w0543 or w543 (year 2005 week 43).
The ISO does present a standard for identifying weeks, but as it does not match up with Gregorian calendar (the beginning and ending days of a given year do not match up), this standard is somewhat more problematic than the other standards for dates.
In British English, full dates are usually written as 7 December 1941 (or 7th December 1941) and spoken as "the seventh of December, nineteen forty-one" (exceedingly common usage of "the" and "of"), with the occasional usage of December 7, 1941 ("December the seventh, nineteen forty-one"). In common with continental European usage, however, all-numeric dates are invariably ordered dd/mm/yyyy.
In the United States, the usual written form is December 7, 1941, spoken as "December seventh, nineteen forty-one" or colloquially "December the seventh, nineteen forty-one". Ordinal numerals, however, are not always used when writing and pronouncing dates, and "December seven, nineteen forty-one" is also an accepted pronunciation of the date written December 7, 1941. A notable exception to this rule is the Fourth of July.